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Inventors: Chaitanya Kanojia, Lee Kamenstky, Peter Hall, and Ian Copeman 
Attorney's Docket No.: 2657.2001002 



METHOD AND SYSTEM FOR CONTENT DEPLOYMENT AND ACTIVATION 

RELATED APPLICATION 

This application claims the benefit of U.S. Provisional Application No. , 

Attorney Docket No. 2657.2001000, entitled "System and Method for Targeting 
5 Network Devices for Content Deployment", by Chaitanya Kanojia, Lee Kamenstky, 
Peter Hall, and Ian Copeman, filed on February 25, 2000, the entire teachings of which 
is incorporated herein by this reference. 

BACKGROUND OF THE INVENTION 

1 0 Generally, under the current state of technology and in the past, television has 

been delivered to the residential home either through radio-frequency broadcasts, 
satellite downlink, or over coaxial cable television (CATV) network. Data network 
communications, such as Internet access, have been delivered via the telephone 
networks through dial-up connections, ISDN (Integrated Services Digital Network), and 

15 DSL (Digital Subscriber Line) lines or over hybrid broadcast/data CATV networks, 
where a portion of the bandwidth transmitted by the coaxial cable is allocated for shared 
data network functionality using a CSMA/CD-style transmission protocol. Less 
commonly, data connections to the home are provided via satellite links where data are 
downloaded via the satellite link and uploads are handled through land lines, such as the 
20 telephone network. Another technique is to transmit data to the home via wireless, 
CAMA, for example, links. 
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Almost universally, the clients or network devices in the residences are personal 
computers. Typically, they execute application programs such as email clients and 
browsers that utilize the data network connectivity offered by one of the above 
techniques. 

5 The trend, however, is towards a more ubiquitous computing model where the 

network devices in the home will be embedded systems designed for a particular 
function or purpose. This has already occurred to some degree. Today, for example, 
CATV network set-top boxes typically have limited data communication capabilities. 
Their main function is to handle channel access issues between residential users and a 
1 0 server on the cable TV network. 

In the future, the functionaUty offered by these set-top boxes or other embedded 
platforms, such as a game system, will be expanded. For example, they may offer 
Internet browsing capabilities and e-commerce serving capabilities. Moreover, it is 
anticipated that common-household appliances will also have network functionality, in 
1 5 which they will be attached to the network to automate various tasks. 

The data networks must evolve with deployment of these embedded systems. 
Where the personal computer can be updated with new network drivers as the network 
evolves, embedded chent systems remain relatively static. Moreover, the process of 
installation in the residence must be made less complicated so that a network technician 
20 is not required every time a new embedded device is connected onto the network, 

SUMMARY OF THE INVENTION 

Previously, techniques have been developed that allow information to be 
downloaded to a television or set-top box. For example, under the standards established 
by the Advanced Television Enhancement Forum (ATVEF), HTML can be embedded 
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in a video signal. Many previous systems have enabled information to be inserted into 
the vertical blanking interval of a video signal. 

The problem is that these techniques are broadcast-based- with the same content 
being transmitted to all the devices that receive the video signal. They can not target 
5 users with specific attributes. In addition, these techniques require sophisticated video 
editing to insert information into the video signal. 

The present disclosed system is directed toward a communication and 
management system that can dynamically targets network devices for content 
deployment, such as appHcation programs, device drivers, configuration files, and 
10 registry subhives. Moreover, the present system targets users of network devices for 
promotions, such as advertisements offered by Internet, or other network, e-commerce 
sites. Promotions are generally icons or graphic images with links to host web servers 
overlaying a video display, but also includes audio and video clips or data streams. 

Network devices and their users are targeted through user profiles. User profiles 
15 are created when network devices register with the system server and are continually 
updated with information provided by user activity and event logs that are periodically 
uploaded from each device. 

The present invention implements a scalable messaging system for data 
transmission between the system server and among the network devices such that it is 
20 neutral as to the specific hardware platforms on which it is implemented. 

One area of interest concerns the deployment (i.e. download and installation) of 
content to the network devices. 
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In general, according to one aspect, the present invention concerns a system for 
deploying content to targeted network devices over a data network. The system 
comprises a content store that stores the deployable content. A system manager then 
schedules the download of the content from the data store to targeted network devices. 

5 Further, the system manager delivers criteria, set by the system administrator, 

for the activation of that content on the network devices. In this way, the present 
invention avoids the need to universally broadcast the content. It is downloaded, 
installed, and then activated based on specific criteria. 

As a result, a system constructed according to these principles allows for 
10 targeted deployment of the content. This content, then residing on the network device, 
is activated in response to established criteria. 

In specific embodiments, the system manager selects targeted network devices 
among all of the network devices in response to profile information associated with 
those network devices. For example, the content can be targeted for deployment only to 
15 network devices in homes meeting predefined financial criteria. 

Moreover, the deployment of content can be scheduled during off-peak periods 
of network activity. For example, during the early morning hours, data network activity 
is generally low and an optimal time for deployment. In other embodiments, the server 
system can actually monitor the network for periods of low network usage and schedule 
20 deployment during such periods. 

In the preferred embodiment, a bulk data manager has access to the content 
store. It communicates with a bulk data transfer agent, executing on the network device, 
to move the content from the server system to the specific network device. 
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Once content is deployed, various types of activation criteria can be employed. 
Scheduled activation and event driven activation are two such methods of activating 
content at the network devices. 

Scheduled activation includes activating content in response to a predetermined 
5 date and time as well as activation via start messages from the system server. 

Event driven activation includes activating content based on the occurrence of 
events specified in an event map, such as channel events. 

In the case of promotions, event driven activation also includes the activation of 
promotions triggered by HTML tags, or other triggers, embedded in a video signal. 

10 In general, according to another aspect, the invention can also be characterized 

in the context of a method. The invention, in general, concerns a method for deploying 
content to network devices over a data network. This method comprises storing content 
on content store of a server system. The content is then scheduled for deployment from 
the system server to targeted network devices. Activation criteria is also downloaded to 

1 5 those targeted network devices. 

The above and other features of the invention including various novel details of 
construction and combinations of parts, and other advantages, will now be more 
particularly described with reference to the accompanying drawings and pointed out in 
the claims. It will be understood that the particular method and device embodying the 
20 invention are shown by way of illustration and not as a limitation of the invention. The 
principles and features of this invention may be employed in various and numerous 
embodiments without departing from the scope of the invention. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

In the accompanying drawings, reference characters refer to the same parts 
throughout the different views. The drawings are not necessarily to scale; emphasis has 
instead been placed upon illustrating the principles of the invention. 
5 Of the drawings: 

Fig. 1 A is a schematic block diagram depicting a cable network infrastructure in 
which one embodiment of the present invention functions. 

Fig. IB is a schematic block diagram depicting a sateUite network infrastructure 
in which another embodiment of the present invention functions. 
] 1 0 Fig. 1 C is a schematic block diagram depicting a Digital Subscriber Line (DSL) 

Q network infrastructure in which still another embodiment of the present invention 

J": functions, 

'■^^ Fig. ID is a schematic block diagram depicting a wireless network infrastructure 

D in which another embodiment of the present invention functions. 

15 Fig. 2 A is a block diagram depicting the interaction of the components of the 

y server system and the embedded client system according to the invention. 

L'; Fig. 2B is a process diagram illustrating the interaction between a queue 

manager and the message router according to the invention. 

Fig. 2C is a process diagram illustrating a process for delivering a message via 
20 the message router according to the invention. 

Fig. 3 is a state line diagram illustrating a process for automatically registering a 
device and generating user profiles for targeting content according to the invention. 

Fig. 4A is a state line diagram illustrating a process for targeting consumers with 
content (e.g., graphical promotion) and deploying the content to a targeted device 
25 according to the invention. 

Fig. 4B is a process diagram illustrating a process for scheduling activation of 
content with a predetermined date and time according to the invention. 

Fig. 4C is a process diagram illustrating a process for scheduling activation of 
content by server activation according to the invention. 
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Fig. 4D is a process diagram illustrating a process for event driven activation of 
content according to the invention. 

Fig. 4E is a block diagram depicting event driven activation involving trigger 
signals in the video stream according to the invention. 

Fig. 5A is an example of the Document Type Definition used to define the 
document structure of the user activity and event logs written in XML (Extensible 
Markup Language) according to the invention. 

Fig. 5B is an example of the representation of events stored in a user activity and 
event log written in XML according to the invention. 

Fig. 6 is a state line diagram illustrating a process for automatically for updating 
user profiles through uploading and parsing user activity and event logs according to the 
invention. 

Fig. 7 is a process diagram illustrating a process for dynamically installing a 
driver on a network device according to the invention. 
1 5 Fig. 8 is a flow diagram showing the uninstallation of the driver on the network 

device according to the invention. 



DETAILED DESCRIPTION OF THE INVENTION 

The present invention is a communications and management system executing 
over a data network for targeting content, including promotions, to users of network 
devices whose attributes match the attributes of a group profile along with maintaining 
those network devices. 



20 



over a 



The system and methods of the present invention can be implemented ^ 
variety of data network infi-astructure including cable, satelhte, Digital Subscriber Lines 
(DSL), and wireless networks. 

25 Fig. 1 A shows one embodiment of the present invention in which the 

communications and management system is implemented over a cable network. In this 
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environment, audio and video broadcasts are typically frequency multiplexed with data 
transmissions on the coaxial cables extending from the head end 50 to the exemplary 
network devices 80A, SOB, 80C, and SOD (collectively referred to as SO). 

Video content providers 20 as well as Internet content providers 10 (i.e. host 
web servers) dehver their audio/video/data signals to a cable service provider/internet 
service provider (CSP/ISP) data center 40. The Internet content providers 10 deliver 
their data to the data center 40 via the Internet 30. Typically, video content providers 
20 transmit their video signals to the data center 40 via some broadcast medium, such as 
conventional radio -frequency television broadcasting techniques, or via a digital 
sateUite downlink. 

The CSP/ISP data center 40 transmits the audio/video/data signals to multiple 
head ends 50 (only one being shown for simplicity of illustration). The connection 
between the data center 40 and the head end 50 is typically a hybrid CATV/data 
connection, which is supported by an optical fiber infrastructure. Part of this 
1 5 infrastructure carries the audio/video signals, which are directed from the data center 40 
to the network devices SO. Part of this network also carries the bi-directional data 
communications associated with network control and internet service provisioning. 

The head end 50 distributes the audio/video/data signals over a cable network of 
hubs 60 and local nodes 70 to a variety of network devices SO, such as set-top boxes, 
20 web phones, and cable modems. Some network devices SOD, such as a web phone, 
have a built-in video display 310 and speaker system 315. Other network devices 80C 
are peripherally attached to a video display device and speaker system such as a 
television 300. 

In one embodiment of the present invention, the server system (lOOA and lOOB, 
25 collectively referred to as 1 00), is located at the CSP/ISP data center 40 and the head 
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end 50 of the cable network. Installation of the server system at the data center 40 and 
the head end 40 allows for scalability. The server system 100 A at the data center 40 
typically provides centralized management for configuring group profiles and content 
deployment options, while the server system lOOB at the head end 50 preferably handles 
5 the registration, user profile updates, content deployment, and other services among the 
network devices 80. 

There are alternative schemes for deploying the server system 100 withm the 
cable network infi-astructure depending on the capacity of the server system 100 and 
number of network devices 80. For example, the server system 100 is deployed at the 
1 0 hub 60 level when the population of devices is sufficiently dense to necessitate such 
distribution of the communication load. 

Fig. IB shows an embodiment of the present invention in which the 
communications and management system is implemented on a satellite network. In this 
environment, the server system 100 is located at data center 45. 

1 5 The server system 1 00 transmits data to the network devices 8 0 via a satellite 

uplink device 90 to a satellite 93, which, in turn, transmits the data to a residential 
satellite downlink dish 95. The data are received by the network devices 80 connected 
to the downlink feed 97. 

For the return, upload, path, the network devices 80 transmit data to the server 
20 system 1 00 through a built-in modem, other dial-up device, or a land line system such 
as ISDN or DSL. The modem connects to a centi-al office or point-of-presence (POP) 
55, which, in turn, transmits the return-path data over the Internet 30 to the data center 
45. 
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Fig. IC shows an embodiment of the present invention in which the 
communications and management system is implemented on a Digital Subscriber Line 
(DSL) network. In this environment, the server system 100 is located at data center 45. 

The server system 100 communicates bi-directionally with the network devices 
80 via the Internet 30 or closed network connection, such as frame-relay, to a central 
office or point-of-presence (POP) 55. In one embodiment, the Internet connection 
between the server system 100 and the central office 55 is over a Virtual Private 
Network (VPN) providing a private, secure, encrypted connection tunnel. 

The network devices 80 are connected to the Internet 30 by the central office 55 
via Digital Subscriber Lines (DSL). 

Fig. ID shows an embodiment of the present invention in which the 
communications and management system is implemented on a wireless network. This 
environment is similar to the DSL network with the exception that the network devices 
80 are connected to the Internet 30 by the central ofSce 55 via wireless, typically 
CDMA, connections. 

Fig. 2 A shows the organization of the server system 100 and the embedded 
chent system 200 interacting to implement the communications and management 

system. 

In brief overview, the server system 100 includes a management console 1 10, a 
system manager 120, a data store 130, a queue manager 140, a message router 150, a 
bulk data transfer manager 160, and an XML file processor 170. The embedded client 
system 200 executing in the network devices include a web browser 210, a system agent 
220, a promotion notification agent 230, a queue manager 240, a logging agent, 250, 
and a bulk data transfer agent 260. 
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In more detail, the management console 100 is preferably implemented as a web 
server. In one embodiment of the present invention, the management console 100 is a 
Microsoft® Internet Information Server (IIS) implementing Active Server Pages 
(ASP). 

5 The management console 100 provides, upon request by a system administrator, 

a web page interface for specifying the content to deploy, the attributes of a group 
profile that target a market segment of potential consumers, installation information, 
and criteria for activating the content or displaying the promotions at the network 
devices. Upon submitting the web page, the management console 100 communicates 
10 with the system manager 120, via an Application Programming Interface (API) to store 
the targeted group profile, activation criteria, and the content and promotions to the data 
store 130. In one embodiment the API is a Microsoft® COM interface. 

Content includes, but is not limited to, applications, device drivers, data files, 
registry sub-hives, and promotions. Promotions are a special type of content that 
1 5 advertise goods and services. Promotions overlay the video display of a network 
device with a graphic, image, or animated icon that launches a web browser to a host 
web server in response to the user cHcking or selecting it. Promotions also include 
audio and video clips or data streams. One or more promotions can be displayed on the 
video display at one time. 

20 The management console 110 also provides a web page interface to users upon 

request during the initial registration of their network devices. Users will register 
through the web page interface, providing data about themselves. Upon submitting the 
web page, the management console 110 communicates with the system manager 120, 
via the COM interface, to store the user data as attributes of a user profile. The 

25 attributes of the user profile are associated with the attributes of the group profile in 
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order to target potential consumers who would be interested in the content or 
promotions. 

The system manager 120 is an apphcation-level process that manages the 
reading and writing of data to the data store 130. The system manager 120, through its 
5 COM interface, allows the management console 1 10 to store user profiles, content 

including promotions along with associated group profiles, installation information, and 
activation criteria. In addition, the system manager 120 updates the user and group 
profiles whenever new attributes are received. 

The system manager 120 also interacts with the system agent 220 of the targeted 
10 network devices by sending and receiving messages through a messaging protocol. The 
interaction of the system manager 120 and the system agent 220 implement the 
scheduling of content deployment as well as installation and activation of the content. 
In one embodiment, the system manager is implemented as a Microsoft® COM object. 

The queue manager 140 is an application-level process that communicates with 
15 the message router 150 on behalf of other processes, such as the system manager 120, in 
order to send and receive messages among the embedded client systems 200. In one 
embodiment, the queue manager 140 is implemented as a C++ object. The queue 
manager 140 also manages incoming and outgoing queues on behalf of the other 
processes in the system server 100. 

20 The queue manager 140 handles two types of queues, persistent queues and 

volatile queues. Messages, whose message type indicates persistent storage, are stored 
such that the message will not be lost during power outages and lost network 
connections. A persistent queue is stored in persistent flash memory or in a location on 
the hard disk of the network device. Other messages, not intended for persistent 
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storage, are stored to volatile queues and might be lost during power outage and lost 
network connections. 

The data store 130 is a database that stores the attributes of the user profiles, 
group profiles, content and promotions along with the activation criteria. In addition, the 
5 data store 130 stores messages intended for network devices that are unavailable during 
the initial dehvery attempt. The data store provides persistence to the data stored such 
that the content, profiles, and messages will not be lost during a power outage. In one 
embodiment, the data store 130 is a Microsoft® SQL version 7 database. Since the data 
store stores content, it is also known as a content store. 

The bulk data transfer manager 160 is an application-level process that is 
responsible for the transfer of bulk data to targeted network devices. Bulk data include 
large stream-oriented data, such as a promotions, files, or registry sub-key hives. The 
bulk data transfer manager 160 does not transmit data over the messaging protocol. 
Instead, it transmits serialized data over a network transport protocol, such as TCP/IP. 
The bulk data transfer manager 160 has access to the data store 130 for transmitting 
content and promotions. 

The XML File Processor 170 is an application-level process that is responsible 
for parsing out the user attributes from the raw user activity and event logs and updating 
the appropriate user profiles. In one embodiment, the logs are stored as XML files in 
20 the data store 130. 

In more detail of the embedded client system 200, the system agent 220 is an 
application-level process that communicates with the system manager 120 handling 
various request messages and registration. In handling the various request messages, 
the system agent communicates with the other embedded client system components in 
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order to effect a proper response or behavior. In one embodiment, the system agent 220 
is implemented as a C++ object. 

As in the system server, the queue manager 240 is an application-level process 
that communicates with the message router 150 on behalf of other processes, such as the 
5 system agent 220, in order to send and receive messages to the system server 1 00 and 
other network devices. In one embodiment, the queue manager 240 is implemented as a 
C++ object. The queue manager 240 also manages incoming and outgoing queues on 
behalf of the other processes in the embedded client system 200. 

The queue manager 240 handles two types of queues, persistent queues and 
10 volatile queues. Messages, whose message type indicates persistent storage, are stored 
such that the message will not be lost during power outages and lost network 
connections. A persistent queue is stored in persistent flash memory or in a location on 
the hard disk of the network device. Other messages, not intended for persistent 
storage, are stored to volatile queues and might be lost during power outage and lost 
15 network connections. 



The bulk data transfer agent 260 is an application-level process that handles 
requests from the system agent 220 to either download content and promotions or 
upload user activity and event logs. The bulk data transfer agent 260 communicates 
with the bulk data transfer manager 160 of the system server 100 over a network 
transport protocol, such as TCP/IP. The bulk data transfer agent 260 notifies the system 
agent 220 upon completion or failure of the data transfer. In one embodiment, the 
system agent 220 is implemented as a C++ object. 

The promotion notification agent 230 is an apphcation-level process that 
triggers and handles the display of promotions. The promotion notification agent 230 
overlays the promotion or promotions onto the video signal that gets displayed on a 
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monitor connected to a set-top box or to a web phone display. The promotion 
notification agent 230 coordinates the activation of promotions. A promotion 
notification agent 230 will display the promotion in response to an event, invocation by 
the system manager 120, or scheduling information provided with the promotion itself 

5 The web browser 210 is an application-level process that displays web pages 

from web host servers such as the management console 1 10 of the system server 100 
enabling registration of user attributes. 



The logging agent 250 is an application-level component that monitors and logs 
a variety of user activities and events. In one embodiment, the logging agent 250 stores 
1 0 the log files in XML format. User activities and events that are tracked by the logging 
agent 250 are channel events, promotion events, power events, peripheral events, and 
application events. 



Channel events occur whenever the network device stays tuned to a channel for 
a configurable amount of time. Promotion events occur in response to consumer actions 
15 taken with respect to promotions displayed on the video display. For example, a 

promotion event is recorded when the consumer clicks or selects the promotion icon to 
navigate to the web server hosting the promotion. 

The interaction of the server system 100 and the embedded client system 200 
provides a system for targeting and scheduling deployment of promotional content to 
20 consumers of a targeted market segment, for managing the activation of the promotional 
content, and for tracking consumer response to the promotion. 

Apphcation-level processes, such as the system manager 120 of the server 
system and the system agent 220 of the network device, communicate over the data 
network through messages. 
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Messages transfer requests for action, responses to requests, and small data 
transfers. Messages are transported in the payload of a network transport protocol, such 
as TCP/IP. Messages are sent to destinations using a globally unique identifier, GUID, 
in order to identify the destination network device or application. This messaging 
protocol allows appUcation-level processes to transmit data without knowing about the 
network transport interface, the device's network address, or whether the device is 
active on the data network. 

The interaction of the message router 150 with the queue managers of the source 
and destination processes implements the messaging protocol. Any queue manager 
whether it is executing on the system server 100 or the embedded client system 200 
communicates with the message router 150 in the same manner. 

Fig. 2B illustrates the interaction between a queue manager and the message 
router 150 according to the invention. For example, when the system manager 120 
needs to transmit a message to a system agent 220, the system manager 120, in step 
1000, sends the message to the queue manager 140 indicating the message type, a 
globally unique identifier (i.e., GUID) of the destination device, and the message data. 
The details on how a network device obtains a GUID is described later with reference to 
Fig. 3. 

In step 1002, the queue manager 140 stores the message in a queue for the 
system manager 120 and then attempts to establish a connection with the message router 
150. 

In brief overview, there are three steps in order for the queue manager 140 to 
establish a connection to the message router 150. In step 1004, the queue manager 140 
determines the IP address of the message router 150. In step 1006, the queue manager 
140 creates and opens a socket pair connection to the message router 150 for 
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transmitting serialized data. In step 1008, the queue manager 140 sends a message to 
the message router 150 indicating that the queue manager 140 is alive and connected 
and ready to transmit serialized data. 

In more detail of step 1004, the queue manager 140 has one of its properties 
5 being the location or name of the message router 1 50. Using DNS, or IP host name 
services, the queue manager 140 determines the IP address of the message router 150. 
If the queue manager 140 cannot resolve the IP address of the message router 150, the 
queue manager 140 resorts to a broadcasting scheme. The queue manager 140 
broadcasts a locator message on its subnet attempting to locate the message router 150. 
1 0 If there is a message router 1 50 on that subnet, the message router 1 50 responds back 
with its IP address. This address is cached by the queue manager 140 for future 
connections. 

In step 1006, the queue manager 140, knowing the IP address of the message 
router 150, creates and opens a socket pair on predetermined, known ports for 
1 5 transmitting serialized data. 

In step 1008, once the socket pair is opened, the queue manager 140 sends a 
message notifying the message router 150 that the queue manager 140 is alive and 
connected and has socket pairs on which to read or write seriahzed data. 

In step 1010, the queue manager 140 writes the message for dehvery to the 
20 message router 1 50 through the established TCP/IP socket connection 

Fig. 2C illustrates the process of delivering the message once received by the 
message router 150. 
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Upon completion of the writing of the message, the message router 150 extracts 
the message type and the destination GUID from the message in step 1012. 

In step 1014, the message router 150 resolves the destination GUID by looking- 
up the IP address associated with the GUID in the data store 130. 

In step 1016, the message is encapsulated in an IP packet, with the appropriate 
destination IP address. In one embodiment, the IP address of the network device 
becomes known to the system server 100 during initial registration of the network 
device and is stored as an attribute of the user profile. 

In step 1018, the message router 150 determines the type of the message. The 
message type indicates the quality of service that the message router 150 provides for 
dehvery of the message. 

If the message type is a standard datagram, the message router 150 simply 
transmits the message in step 1022. The message router 150 will not keep track of 
whether the message was actually received. 

If the message type indicates guaranteed delivery, the message router 150 will 
transmit the message and wait for an acknowledgment from the destination device in 
step 1024. 



If no acknowledgment is received after several attempts, the destination is 
deemed unavailable and the message is stored in the data store 130 for later 
refransmission when the destination is active on the data network in step 1028. 
Specifically, in step 1029, the message router waits for the network device 80 to become 
active in order to deliver the message. In one embodiment, the message router 150 is 
notified that the network device is active by receiving a message from the network 
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device 80 indicating its active status. In an alternative embodiment, the message router 
is notified of the active status of a previously unavailable network device by the system 
manager 120 which monitors the status of the network devices 80. When the network 
device becomes active, the message router proceeds back to step 1018 to begin the 
5 process of delivery again. 



If the acknowledgment is received, then, in step 1030, the delivery is complete 
and the message is removed from the data store 130 if the network device was 
previously unavailable. 



The mteraction of the message router 150 and the queue manager 140 for 
] 0 delivering messages occurs whenever a message is sent or received using the messaging 
protocol. 

In order for the server system 100 to target content and promotions to a 
particular market segment, the server system 100 references its stored user profiles, each 
user profile being a collection of user and device attributes associated with a network 
1 5 device. All network devices whose user profiles match the attributes of the group 
profile, targeted by a system administrator, are scheduled for content deployment. 

However, when a network device is connected to the network infrastructure for 
the first time, the system server does not have a user profile for the network device. The 
present invention provides an automated system aud method for initially registering and 
20 generating a user profile for an network device. 

Fig. 3 is a state line diagram showing the interaction of the server system 100 
and the embedded client system 200 for generating an initial user profile for a network 
device. 
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In step 1, the system agent 220 of the network device generates and transmits a 
registration request message containing a number of device attributes to the system 
manager 120. 

The device attributes describes the network device and is configured during the 
manufacturing process of the device itself For example, the network device may be 
configured with a model number attribute for a particular group of network devices, 
such as intelligent set-top boxes, version 1.0. 

In step 2, the system manager 120 receives the registration request message and, 
in response, retrieves a globally unique identifier, GUID, from an available pool of 
GUIDs stored in the data store 130. 

In step 3, the system manager 120 generates and transmits a registration 
response message containing the assigned GUID to the system agent 220 of the 
registering device. 

The assigned GUID is used by the network device to identify itself in messages 
transmitted to the system server 100 and to other network devices. The assigned GUID 
is also used by the system server 100 to associate the network device with a user profile 
within the data store 130. 

In step 4, the system agent 220 launches a web browser 210. The web browser 
210 transmits an HTTP request to the URL (Uniform Resource Locator) of the 
management console 110 for a registration web page. The assigned GUID is included in 
the URL string in order to identify the registering network device. 

In step 5, the management console 110 receives the HTTP request. In response, 
the management console 1 10 makes a call via the COM interface of the system manager 
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120 to retrieve the device and user attributes, if any, associated with the GUTD of the 
registering network device. The management console 1 10 generates the registration 
web page customized for the registering network device. The web page is transmitted 
via HTTP to the web browser 210. 

5 In step 6, the web browser 2 1 0 displays the registration web page wherein the 

user submits information which will be used to generate a user profile of user attributes 
associated with the network device. Such information includes, but is not limited to, 
name and address information, channels frequently watched, requests for installation of 
optional value-add services and applications, and various demographic and personal 
10 information. 

Upon submitting the registration data, the web browser 210 transmits the user 
attributes, represented as HTML data via HTTP, to the management console 1 10. 

In step 7, the management console 1 10 interprets the HTML data stream and 
makes calls via the COM interface of the system manager 120 to update the user 
1 5 profiles in the data store 1 30 with the provided user attributes. 

In step 8, the system manager 120 updates the user profile of the registering 
network device with the user attributes on the data store 130. After updating the user 
profile, the system manager 120 associates the user profile with group profiles whose 
attributes match user attributes of the user profile. 

20 For example, the user profile will be added to the group profile for network 

devices with the same model number attribute. The user profile is added to any number 
of group profiles that target particular attributes of the registered user or network device. 
These group profiles are used by the system manager 120 for targeting consumers of 
particular market segments for various e-commerce promotions or application services. 
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Once the network device is registered and is associated with a user profile, the 
device is capable of being targeted for deployment of content or promotions. 

Fig. 4A is a state line diagram showing the interaction of the server system and 
the embedded chent system for deployment of content and promotions to a network 
5 device. Deployment includes, but is not limited to, downloading and installing. 

Before content can be deployed to a targeted device, the content must be stored 
in the data store 130 along with a group profile and an activation schedule. The group 
profile indicates the attributes of network devices to target. The activation schedule 
indicates when to activate the content or promotions. Activation can be event driven, 
10 scheduled from the system server 100, or initiated by the system manager 120. 

In step 1, a system administrator with access to the management console 110 
populates a server-based web page indicating the content to deploy as well as the 
criteria with which to define the group profile. Additionally, the system administrator 
indicates when to activate the content. Upon submitting the data, the management 
1 5 console 110 makes a call to the COM interface of the system manager 120 to generate a 
group profile in the data store 130 with user profiles whose attributes match the criteria 
defined by the system administrator. 

In step 2, the system manager 120 updates the data store 130 creating the group 
profile and populating the group profile with user profiles with matching attributes. 

20 In step 3, the management console 1 1 0 make a call through the COM interface 

of the system manager 120 to download the content or promotion to the data store 130. 

In step 4, the system manager 120 writes the content to the data store 130. 
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The system manager 120 is configured to schedule deployment of content during 
off-peak hours when bandwidth utilization is typically at a minimum. For example, 
during the hours of 3:00AM and 5:00AM, more bandwidth is available for efficient 
deployment of content and promotions. Alternatively, the system manager 120 
5 monitors network utilization and is configured to schedule deployment of content when 
the detected bandwidth utilization falls below a predetermined level. 



In step 5, the system manager 120 sends a dovmload and install request message 
to each of the system agents 220 of the network devices whose user attributes match the 
attributes of the group profile. The download and install message informs the system 
10 agent 220 to download install the content or promotion referenced by a GUID. 

Alternatively, the system manager 120 sends a download, install, and start 
request message which indicates, in addition, when or under what event conditions the 
content should be activated (i.e. promotion displayed or an application launched). 

In step 6, the system agent 220 makes a C++ object method call to the bulk data 
1 5 transfer agent 260 to download the content having the provided GUID, 

In step 7, the bulk data transfer agent 260 sets up a TCP/IP socket connection to 
the bulk data transfer manager 160 of the server system to initiate the delivery of the 
application. 



In step 8, the bulk data transfer manager 160 delivers the requested content to 
20 the bulk data transfer agent 260 through the TCP/IP socket connection. In cases where 
the connection is broken, the bulk data transfer agent 260 and the bulk data transfer 
manager 160 can detect that a connection was broken and will continue the download 
the content from the point in the transfer where the break occurred. 
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In step 9, the bulk data transfer agent 260 notifies the system agent 220 the result 
of the data transfer via an C++ object method call. 

In step 10, the system agent 220 sends a message to the system manager 120 
indicating the result of the data transfer. 

5 After the content is installed on the targeted network device, the present 

invention provides a system and method for activating that content. Activation allows 
the user to interact with the installed content, such as playing a game or initiating an e- 
commerce transaction. 

There are two types of activation that the present invention implements - 
10 scheduled activation and event driven activation. Scheduled activation allows the 
system administrator to specify when to activate the content, whereas event driven 
activation allows the system administrator to specify an event which triggers the 
activation of the content. 

Scheduled activation is implemented in two ways, predetermined scheduling and 
15 activation by the system server. 

Fig, 4B illustrates the steps associated with content activation via predetermined 
scheduling. Predetermined scheduling based upon date and time provides the most 
autonomy to the network device. After the content is deployed, the network device 
simply waits for the specified date and time to arrive, at which time it displays the 
20 content. 

In step 1110, when the group profiles are configured and the content is 
downloaded to the data store 130, the system administrator also specifies the date and 
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time to activate the content. Where the content is a promotion, a duration period is 
specified along with the activation date and time. 

In step 1 1 12, the system manager 120 sends the download, install, and start 
request message to the system agent 220 of a targeted network device. In addition to 
5 requesting the system agent 220 to install content, the message indicates the date and 
time to activate the installed content. 

If the content is a not a promotion, the system agent 220 waits for the specified 
activation date and time in step 1116. 

In step 1 1 1 8, the content is activated by the system agent 220 at the specified 
10 date and time. 

If the content is a promotion, the system agent 220 transfers the predetermined 
date, time, and duration to the promotion notification agent 230 in step 1120. 

In step 1 122, the promotion notification agent 230 waits for the specified 
activation date and time. 

15 In step 1 124, the promotion is activated by the promotion notification agent 230 

at the specified activation date and time. 

If the promotion is a icon or graphic linked to a URL of a host web server, the 
promotion notification agent 230 overlays the promotion on a portion of the video 
display built-in or attached to the network device. If the promotion is audio clip or data 
20 stream, the audio is played through a speaker built-in or attached to the network device. 
If the promotion is a video clip or data stream, the video overlays a portion of the video 
display built-in or attached to the network device. 
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Fig. 4C illustrates the steps associated with server activation of content. Server 
activation of content allows control to reside at the server system 100, therefore, 
maximizing the control by the institution operating the server system 100. 

As described previously, the content is installed on the network device in step 
5 1210 with no activation information. 

In step 1212, the system agent 220 waits for a start message from the system 
server 100. 

In step 1214, upon request of the system administrator, the system manager 120 
sends a start message to the system agent 220 specifying the installed content to 
activate. 

If the installed content is not a promotion, the system agent activates the content 
in response to receiving the message in step 1218. This may include, but not limited to, 
launching an application installed within the network device. 

If the installed content is a promotion, the system agent 220 notifies the 
1 5 promotion notification agent 230 via a C++ object method call to activate the specified 
promotion in step 1220. 

In step 1222, the promotion is activated by the promotion notification agent 230. 

Event driven activation is particularly suited for coordinating the activation of 
content with a particular event or a particular moment in a corresponding analog and/or 
20 digital video stream. 
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Event activation has advantages associated with high scalability. The content 
can be loaded in the days or weeks preceding the general time period when it is to be 
displayed. 

In one embodiment, events that trigger content activation are channel events, 
5 power events, and peripheral events. A power event is an event relating to the power 
supply, such as the network device being powered on or off. A peripheral event is an 
event relating to peripheral devices being connected or disconnected from the network 
device, such as a joy stick or other gaming console. A channel event is an event relating 
to the channel being watched by the user. 

1 0 Fig. 4D illustrates the steps associated with event driven activation according to 

the invention. 

In step 1310, when the group profiles are configured and the content is 
downloaded to the data store 130, the system administrator also specifies an event map. 
An event map associates events to content indicating when to activate the content. 
15 Where the content is a promotion, a duration period is specified as well. 

In step 1312, the system manager 120 sends the event map in a message, such as 
a download, install, and start message, to the system agent 220 of a targeted network 
device. 

If the content is not a promotion, the system agent 220 waits for the specified 
20 event or events that trigger the activation of the content in step 1316. 

In step 1318, the system agent 220 activates the content when the specified event 
or events occur. 
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Conversely, if the content is a promotion, the system agent 220 transfers the 
event map to the promotion notification agent 230 in step 1320. 

In step 1322, the promotion notification agent 230 waits for the specified event 
or events to occur. 

In step 1324, the promotion notification agent 230 activates the promotions 
associated with the event or events that occurred. 

An example of event driven activation is where the event map provides for the 
activation of promotions involving sporting goods when the potential consumer has 
been watching a particular sports channel for a period of time. The watching of the 
sports chaimel for a period of time triggers a channel event. The channel event triggers 
the activation of the promotion or promotions. 

The present invention provides an additional implementation of event driven 
activation involving technology from ATVEF (Advanced Television Enhancement 
Forum). ATVEF provides a standard for embedding HTML tags within a video signal. 

The promotion content agent 230 monitors the video signal for the embedded 
triggers, such as the HTML tag. The capture of this embedded trigger causes the 
activation of one or more promotions in real-time coinciding with the video signal. 

Such a system has advantages in that very little video signal editing is required. 
Only a small trigger has to be embedded in the video signal, requiring little analog 
video editing capabilities at the data center. 
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The content, is simultaneously activated on all of the network devices allowing 
high levels of synchronization to the video signal. For example, the promotion can be 
synchronized to occur during a television commercial. 

The provider of the commercial simply embeds an initialization or start HTML 
tag within its video signal. In response to the promotion notification agent 230 
capturing the HTML tag, the promotion notification agent 230 activates the appropriate 
promotion or promotions specified in the event map for that HTML tag. 

Fig. 4E shows one embodiment of this system on a conventional set-top box 80 
for an analog or an analog/digital video display device such as a television 300. 
Specifically, the data and audio/video stream is received by the set-top box 80. This 
data audio/video stream is received fi-om the head end 50 via the hub 60. 

The promotion content agent 230 of the embedded client system 200 monitors 
the video stream for the embedded trigger signal. When the trigger signal is detected, 
the promotion content agent 230 inserts the associated graphical promotion content 
indicated in the event map into the analog or digital video stream to the display 3 10 of 
the television 300. As a result, the promotion 320 appears on the display screen 310, 
overlaying the video. 

User selection of this promotion through a selecting device, such as a remote 
control device, sends a URL to the web browser 210 bringing the browser window to 
the forefront of the display 310 of the television 300. In this way, user selection of the 
promotion allows the user to receive and view data from the URL enabling e-commerce 
transactions. 



-30- 



Therefore, the event-driven activation, as well as the other scheduling options, 
presents promotions in an appropriate context to further increase the Hkelihood of 
consumer e-commerce transactions. 

In addition to the initial registration process, the present invention includes a 
system and method for updating user profiles through uploading distributed user activity 
and event logs to the system server 100, parsing out the user and device attributes from 
the logs, and updating the user profiles in the data store 130. 

The logs provide useful information, because the logs track a variety of 
information which the system can use in order to more accurately target users for 
content and promotional deployment. In one embodiment, the logs track channel events 
and e-commerce transactions initiated through the display of promotions. In another 
embodiment, the logs track peripheral events, such as the addition of a joystick and 
console for gaming purposes, power events, application events, and promotion events. 
Continuous updating of user profiles through this system and method improves the 
targeting of consumers for content deployment, and in particular, for promotional 
content deployment. 

In brief overview, the network device includes a logging component 250 that 
monitors and logs user activity and events in an generic file format. For example, the 
logging component 250 monitors user activity at a user interface device such as the 
television remote channel control. In one embodiment, the generic file format is 
Extensible Markup Language (XML). The format of the log files, using XML, 
correspond to the structure of the user profiles in the data store 130. This allows for 
processing of the logs in an automated fashion. 

In addition, the user activity and event logs include a description of the structure 
of the document itself Using XML, the description of the structure of the document is 



2657.2001002 



-31- 

the Document Type Definition (DTD). Providing a description of the document 
stracture within the logs themselves, allows for the server system 100 to process logs 
with different document structures. This avoids the necessity of having to update the 
server system 100 every time a new document structure is used within the logs. 

5 Fig. 5A is an example of a DTD for an event log where each event that occurs is 

recorded with the GUID of the device, the time of the event, the event type, and a 
description of the event. 

Fig. 5B is an example of an event log written in XML using the DTD of Fig. 5A. 
The event log contains two events, stored in the structure described by the DTD. Fig. 
1 0 5B demonstrates how a channel event and an application event are described within this 
log. 

The uploading and parsing of these user activity and event logs will provide 
additional user attributes for targeting consumers including information regarding 
responses to prior promotions. If the logs indicate that a user is interested in a particular 
15 type of promotion, the system server modifies the user attributes of his user profile such 
that they match the attributes of a group profile associated with that type of promotion. 

Fig. 6 is a state line diagram showing the interaction of the server system 100 
and the embedded client system 200 for updating user profiles through the upload and 
parsing of user activity and event logs. 

20 In step 1, the system manager 120 sends a message to the system agent 220 to 

upload its activity logs to the server system. 

In step 2, the system agent 220 makes a C++ object method call to the bulk data 
transfer agent 260 to upload the user activity and event logs. 
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In step 3, the bulk data transfer agent 260 sets up a TCP/IP socket connection to 
.the bulk data transfer manager 160 of the server system to initiate the delivery of the 
logs. 

In step 4, the bulk data transfer agent 260 delivers the logs to the bulk data 
5 transfer manager 160 through the TCP/IP socket connection where they are stored in the 
data store 130. 

In cases where the connection is broken, the bulk data transfer agent 260 and 
the bulk data transfer manager 260 can detect that a connection was broken and will 
continue the download the content from the point in the transfer where the break 
10 occurred. 

In step 5, the bulk data transfer agent 260 notifies the system agent 220 the result 
of the data transfer via a C++ object method call. 

In step 6, the system agent 220 sends a message to the system manager 120 
indicating the result of the data transfer. 

15 In step 7, the system manager 120 makes a call to the XML file processor 170 to 

update the user profiles from the user activity and event logs. 

In step 8, an XML file processor 170 at the server system parses the logs stored 
on the database and updates the user attributes of the user profile of the network device. 
This system and method for scheduling remote uploads of the user activity and event 
20 logs provides improves the efficiency for targeting consumers for content and 
promotion. 
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There are situations where a user will change the hardware configuration of a 
network device in order to expand its capabilities. In that situation, the present 
invention provides a system and method by which the network device notifies the server 
system 100 of a change to its hardware configuration and, in return, receives the 
5 appropriate device drivers to support the new hardware configuration. 

Fig. 7 shows the dynamic installation of device drivers on the network device 
according to the present invention. 

Specifically, the dynamic driver installation process is triggered when the user 
installs a peripheral device on a network device for which the network device requires a 
1 0 driver. In the typical example, the process occurs when the user plugs in a peripheral 
device such as a joy stick into a port such as a serial port or USB (universal serial bus) 
port. 

In step 1002, the system agent 220 intercepts the plug and play string from the 
peripheral device when it is attached to the USB port. 

1 5 In step 1 004 the system agent 220 then sends this plug and play string to the 

system manager 120 via the message router 150 and the queue managers along the path 
between the system agent 220 and the system manager 120. 

In step 1006, the system manager 220 then searches for a matching driver in its 
data store 130. Specifically, it compares the plug and play string received fi-om the 
20 network device to plug and play strings of supported operating systems and supporting 
peripheral devices for which drivers are available. 
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In step 1008, assuming the valid device driver has been located, the system 
manager 120 sends a message to the system agent 220 to download the driver providin 
its location in the data store 130. 

In step 1010, the system agent requests the bulk data transfer agent 260 on the 
5 network device to download the driver. The bulk data transfer agent 260 then contacts 
the bulk data transfer manager 160 and downloads and stores the device driver on the 
network device. In parallel, the system manager 120 instructs the system agent 220 on 
how to install the device driver on the network device. 

In step 1012, in the typical implementation, the device driver is dynamically 
loaded onto the network device. 

In step 1014, when the driver has been successfully installed, the system agent 
220 notifies the system manager 120. The system manager, in turn, updates the status 
of the network device in the system manager's data store 130. 

Fig. 8 illustrates the mirror process in which the peripheral device driver is 
15 uninstalled. 

In step 1016, the system agent 220 is notified when the peripheral is 
disconnected by the user from the network device. 

In step 1018, the system agent 220 then requests an uninstall program from the 
system manager 120. 

20 ]n step 1 020, typically, the bulk data transfer agent 260 obtains the uninstalled 

program from the bulk data fransfer manager 160. 
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In step 1022, the driver is then uninstalled. 

In step 1024, upon the successful uninstall, the system agent 220 notifies the 
system manager 120 that the driver has been installed and the system manager 120 
updates the network device's status. 

While this invention has been particularly shown and described with references 
to preferred embodiments thereof, it will be understood by those skilled in the art that 
various changes in form and details may be made therein without departing from the 
scope of the invention encompassed by the appended claims. 
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CLAIMS 

What is claimed is: 

1 . A system for deploying content to network devices over a data network, 
comprising: 

a content store that stores the content; 

a system manager for scheduling a download of content from the 
data store to targeted network devices and downloading criteria for 
activation of the content on the targeted network device. 

2. A system as recited in Claim 1, wherein the system manager selects the targeted 
network devices among other network devices on the data network based on 
profile information associated with the network devices. 

3. A system as recited in Claim 1, wherein the system manager schedules 
downloading of the content to the targeted network devices during periods when 
usage of the data network is typically low. 

4. A system as recited in Claim 1 , wherein the system manager monitors usage of 
the data network; and initiates downloading of the content to the targeted 
network devices when usage of the data network falls below a predetermined 
level. 

5. A system as recited in Claim 1, further comprising: 

a bulk data transfer manager that has access to the content store; 

and 

a bulk data transfer agent executing in the network devices that 
requests the content from the bulk data transfer manager, the bulk data 
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transfer manager downloading the content from the content store to the 
bulk data transfer agent, which stores the content on the network device. 

6. A system as recited in Claim 5, further comprising: 

a system agent, executing in the network device, the system 
5 manager requesting the system agent to download the content; and the 

system agent requesting the bulk data transfer agent to download the 
content from the bulk data transfer manager. 

7. A system as recited in Claim 1, further comprising a management console that 
provides an interface to identify content for deployment on the network devices, 

1 0 the management console downloading the content to the content store. 

8. A system as recited in Claim 7, wherein the management console further 
provides an interface to identify a group profile for targeting the network devices 
for content deployment, the management console downloading the group profile 
to the content store. 

15 9. A system as recited in Claim 7, wherein the management console further 

provides an interface for identifying activation criteria for activating the content 
on the network devices. 

10. A system as recited in Claim 1, further comprising: 

a system agent executing on the network device; and 
20 the system manager activating the downloaded content sending a 

message to the system agent to activate the downloaded content. 
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11. A system as recited in Claim 1, further comprising a system agent executing on 
the network device, the system agent activating the downloaded content on the 
network device at a predetermined date and time. 

12. A system as recited in Claim 1, further comprising a system agent executing on 
5 the network device, the system agent activating the downloaded content on the 

network device in response to an event. 

13. A system as recited in Claim 12, wherein the event is a channel event, 

14. A system as recited in Claim 12, wherein the event is an attachment of a 
peripheral device to the network device. 

10 15. A system as recited in Claim 1 , further comprising a promotion notification 
agent executing on the network device; wherein the downloaded content is a 
promotion; 

the promotion notification agent activating the promotion in response to 
an event. 

15 16. A system as recited in Claim 1 5, wherein the event is a channel event. 

17. A system as recited in Claim 15, wherein the event is an attachment of a 
peripheral device to the network device. 

18. A system as recited in Claim 1 5, wherein the promotion notification agent 
activates a plurality of promotions on the network device in response to the 

20 event. 



19. 



A system as recited in Claim 1, wherein the data network is a cable network. 
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20. A system as recited in Claim 1, wherein the data network is a satellite-hnked 
network. 

21. A system as recited in Claim 1 , wherein the data network is a Digital Subscriber 
Line network. 

5 22. A system as recited in Claim 1 , wherein the data network is a wireless network. 

23. A system for deploying content to network devices over a data network, 
comprising: 

a content store that stores the content; 

a system manager for scheduling a download of content from the 
1 0 data store to targeted network devices and downloading criteria for 

activation of the content on the targeted network device; and 

a promotion notification agent that activates the content based on 
the activation criteria. 

24. A system as recited in Claim 23, wherein the promotion notification agent waits 
15 for a message from the system agent to activate the content. 

25. A system as recited in Claim 23, wherein the promotion notification agent waits 
for a predetermined date and time established by the activation criteria to 
activate the content. 



26. 

20 



A system as recited in Claim 23, wherein the promotion notification agent 
monitors user activity and waits for a predetermined user action estabhshed by 
the activation criteria to activate the content. 
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21. A system as recited in Claim 23, wherein the promotion notification agent 
monitors a video stream for embedded signal established by the activation 
criteria to activate the content. 

28. A system as recited in Claim 23, wherein the promotion notification agent 
5 monitors a current channel for a television display device and activates the 

content in response to the current channel. 

29. A method for deploying content to network devices over a data network, 
comprising: 

storing content on a server system on the network; 
10 scheduling a download of content from the server system to 

targeted network devices; and 

downloading activation criteria for content on the targeted 
network devices. 

30. A method as recited in Claim 29, further comprising selecting the targeted 

1 5 network devices among other network devices on the data network based on 

profile information associated with the network devices. 

31. A method as recited in Claim 29, further comprising scheduling downloading of 
the content to the targeted network devices during periods when usage of the 
data network is typically low. 

20 32. A method as recited in Claim 29, further comprising: 

monitoring usage of the data network; and 
downloading of the content to the targeted network devices when 
usage of the data network falls below a predetermined level. 
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33. A method as recited in Claim 29, further comprising using a bulk data transfer 
manager and a bulk data transfer agent to download the content to the network 
device. 



34. A method as recited in Claim 29, further comprising an advertiser selecting 

5 activation criteria and target group profile via an interface to the server system. 

35. A method as recited in Claim 29, wherein the step of downloading activation 
criteria comprises downloading a predetermined activation date and time. 

36. A method as recited in Claim 29, wherein the step of downloading activation 
criteria comprises downloading activation event information. 

10 37. A method as recited in Claim 29, further comprising activating the content in 
response to user attachment of a peripheral device to the network device. 

38. A method as recited in Claim 29, further comprising activating the content in 
response to a selected channel for a television display device. 

39. A method as recited in Claim 29, further comprising activating the content in 
1 5 response to a signal embedded in a video stream. 

40. A method for deploying content to network devices over a data network, 
comprising: 

storing content on a server system on the network, wherein the 
content is a promotion; 

20 scheduling a download of the promotion from the server system 

to targeted network devices; 
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downloading activation criteria for the promotion on the targeted 
network devices; and 

activating the promotion by a promotion notification agent based 
on the activation criteria. 
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METHOD AND SYSTEM FOR CONTENT DEPLOYMENT AND ACTIVATION 

ABSTRACT OF THE DISCLOSURE 

The present disclosed system is directed toward a communication and 
management system that dynamically targets network devices for content deployment, 
5 such as application programs, device drivers, configuration files, and registry subhives. 
Moreover, the present system targets users of network devices for promotions, such as 
advertisements offered by Internet e-commerce sites. Promotions are generally icons or 
graphic images with links to host web servers overlaying a video display, but also 
includes audio and video clips or data streams. Network devices and their users are 

10 targeted through user profiles. User profiles are created when network devices register 
with the system server and are continually updated with information provided by user 
activity and event logs that are periodically uploaded firom each device, a scalable 
messaging system provides for data transmission between the system server and among 
the network devices such that it is neutral as to the specific hardware platforms on 

1 5 which it is implemented. 
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<?xml version="1.0" eiicodmg="UTF-8"?> 
<!ELEMENT EventLog(Event)+> 

<!ELEMENT Eveat(gDevice, tTime, wsEventType, wsEventData)-i-> 
<!ELE]VIENT gDevice(#PCDATA)> 
<!ELEMENT tTime(#PCDATA)> 
<!ELE]V[ENT wsEveiitType(#PCDATA)> 
<!ELEMENT wsEventData(#PCDATA)> 




<?xml version="1.0" encoding="UTF-8"?> 

<!DOCTYPE LoggerEvents SYSTEM "LoggerEvents.dtd"> 

<EventLog> 

<Eveiit> 

<gDevice>E2CDBE0-6F85-l 1D3-BFFB-000039ABB70C </gDevice> 
<tTime>2 000/02/04 18:31:02</tTime> 
<wsEventType>CIiaime KwsEventType> 
<wsE ventData>5 3 </wsEventData> 
</Event> 

<Event> 

<gDevice>0000000-0000-0000-0000-000039ABB70C</gDevice> 
<tTime>2000/02/03 06:31:02<tTime> 
<wsEventType>Applicatioii</wsEventType> 
<wsEventData>Laimched</wsEventData> 
</Event> 
<EventLog> 
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